import { getToken, setToken, removeToken, setTimeStamp } from '@/utils/auth'
import { login, getUserInfo, getUserDetailById } from '@/api/user'
import { resetRouter } from '@/router'
// import user from 'mock/user'
const state = {
  token: getToken(),
  userInfo: {} // 定义一个空的对象 不是null 因为后边我要开发userInfo的属性给别人用  userInfo.name
}
const mutations = {
  setToken(state, token) {
    state.token = token
    // 实现 vuex 和 缓存 的同步
    setToken(token)
  },
  removeToken(state) {
    state.token = null
    // 实现 vuex 和 缓存 的同步
    removeToken()
  },
  setUserInfo(state, userInfo) {
    state.userInfo = userInfo
    // state.userInfo = { ...userInfo } // 响应式的变化
  },
  removeUserInfo(state) {
    state.userInfo = {}
  }
}
const actions = {
  async login(context, data) {
    const result = await login(data)
    // axios默认给数据加了一层data
    context.commit('setToken', result)
    setTimeStamp()
  },
  async getUserInfo(context) {
    const result = await getUserInfo()
    const userInfo = await getUserDetailById(result.userId)
    context.commit('setUserInfo', { ...result, ...userInfo })
    return result // 这个retrue 为下文 埋伏笔
  },
  logout(context) {
    // 删除token
    context.commit('removeToken')
    //   删除用户信息
    context.commit('removeUserInfo')
    // 重置路由
    resetRouter()
    // 还有一步  vuex中的数据是不是还在
    // 要清空permission模块下的state数据
    // vuex中 user子模块  permission子模块
    // 子模块调用子模块的action  默认情况下 子模块的context是子模块的
    // 父模块 调用 子模块的action
    context.commit('permission/setRoutes', [], { root: true })
    // 子模块调用子模块的action 可以 将 commit的第三个参数 设置成  { root: true } 就表示当前的context不是子模块了 而是父模块
  }
}
export default {
  namespaced: true,
  state,
  mutations,
  actions
}
